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SYSTEM AND METHOD FOR DYNAMIC DATA CLUSTERING 

Background 

Field of the Invention 

[1001] The present invention relates generally to identifying related data in a database and 
more particularly to a system and method for dynamically determining clusters of related data 
in a database. 

Discussion of the Related Art 

[1002] Vast amounts of data are being collected and stored throughout the world, Tliis 
data may range, for example, from census and demographic information of a population of 
people to genetic information regarding a particular individual and from astronomical 
information of a galaxy to physical properties of sub-atomic particles. One difficulty 
associated with this information is a lack of tools to fiiUy analyze, and therefore, appreciate, 
the content that resides within the collected information. 

[1003] Conventional cluster analysis tools have been developed to analyze relationships 
that may exist among the data in the databases. Clustering tools, which are sometimes also 
referred to as classification algorithms, organize data into meaningfiil groups or "clusters." 
Clustering tools are often used when no a priori hypotheses exist. In other words, clustering 
tools are used to discover otherwise unknown relationships that may exist within the data. 

20 [1004] Several conventional clustering tools have been developed including, for example, 
k-means clustering and self-organizing maps. These conventional clustering tools are 
generally well known and available (e.g., JMP Statistical Discovery Software available from 
SAS Institute, Cary, NC). 

[1005] One problem generally associated with these types of conventional clustering tools 
25 is that they require an a priori estimate of the number of clusters that exist in the data. Once 
an estimate of the number of clusters is determined, these conventional clustering tools force 
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the data into exactly that number of clusters. As is well documented, different estimates of 
the number of clusters can produce very different results with the same data thereby reducing 
the effectiveness of these tools. 

[1006] What is needed is an improved system and method for dynamic data clustering. 

5 

Summary of the Invention 

[1007] The present invention provides a system and method for dynamically identifying 
clusters of related data in a database. According to the present invention, clusters of related 
data, or density pattems, are identified by launching a probe from an initial position in a data 
10 space associated with the data. Each of the data points in the data space attracts the probe to 
O the data point. Distant data points, or collections of data points referred to as clusters, attract 
£ P^^^^ *^ ^ ^^^^^^ extent than proximate data points do. The probe is drawn along a 

trajectory toward an equilibrium point. Once the equilibrium point is reached, a chister is 
y identified and its location optionally stored. Additional probes are launched from different 
1^ 15 initial positions in the data space to identify other clusters that may exist therein until no 
L unique clusters are identified. The collection of identified clusters is representative of a 

number and, in some embodiments of the present invention, a general location of related data 
within the database. 

[1008] One aspect of the present invention not found in conventional clustering 
20 techniques is that an a priori estimate or knowledge of a number of clusters within the 

database is not required. In other words, the present invention dynamically identifies clusters 
within the data space without requiring a number of clusters as an input to its operation. 

[1009] This and other aspects of the present invention will become apparent from the 
following drawings and description. 

25 
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Brief Description of the Drawings 

[1010] The present invention is described with reference to the accompanying drawings. 
In the drawings, like reference numbers indicate identical or fianctionally similar elements. 
Additionally, the left-most digit(s) of a reference number identifies the drawing in which the 
5 reference number first appears. 

[1011] FIG. 1 illustrates a system according to an embodiment of the present invention. 

[1012] FIG. 2 illustrates a data space formed by data records in a database according to an 
embodiment of the present invention. 

[1013] FIG. 3 illustrates an operation of an embodiment of the present invention that 
10 identifies a number of and a location for clusters in a data space. 

£ [1014] FIG. 4 illustrates an operation of identifying a particular cluster in the data space 

ffi according to an embodiment of the present invention. 

% [101 5] FIG. 5 illustrates a trajectory formed by an embodiment of the present invention as 

f a cluster is identified in the data space. 

p 1 5 [1016] FIG. 6 illustrates various clusters identified in the data space in accordance with an 

5f embodiment of the present invention. 

[1017] FIG. 7 illustrates a plot of a potential fimction that may be used in one 
embodiment of the present invention. 

[1018] FIG. 8 illustrates a linear display that may be used to convey information to a user 
20 according to one embodiment of the present invention. 

[1019] FIG. 9 illustrates indicia that may be used to convey a relative value and sign of a 
parameter according to one embodiment of the present invention. 
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Detailed Description 

[1020J The present invention provides a system and method for dynamically identifying 
clusters of related data. Generally speaking, according to the present invention, clusters of 
related data (also known as density patterns) are identified by probing the data in the database. 
5 The database may be comprised of a plurality of records each having one or more data fields. 
The number of data fields, or subset of the number of data fields, "M" in the database 
describes an M-dimensional "data space" representative of all possible combinations of data 
values for these data fields. The plurality of data records in the database correspond to "N" 
data points within that data space. 

10 [1021] According to the present invention, a probe is "launched" fi-om an initial position 
in the data space. Each of the data points in the data space operates on the probe by attracting 
yrj the probe to the data point. Distant data points attract the probe to a lesser extent than 
proximate data points do. Various data points operate on the probe, drawing it along a 
^ "trajectory" toward an equilibrium point within a group of data points or "cluster" where the 
15 probe remains at "rest." Once the equilibrium point is determined in this maimer (and a 
' cluster associated therewith identified), another probe is launched fi^om a different initial 
H position in the data space to identify another cluster that may exist therein. Additional probes 
are launched until no other unique clusters are identified. The collection of identified clusters 
|J is representative of a number and, in some embodiments of the present invention, a general 
20 location of related data within the database. 

[1022] One aspect of the present invention not found in conventional clustering 
techniques is that an a priori estimate or knowledge of a number of clusters within the 
database is not required. In other words, the present invention dynamically identifies clusters 
within the data space without requiring a number of clusters as an input to its operation. This 
25 is discussed in fiirther detail below. 

[1023] An overview of a system operating according to the present invention for 
dynamically identifying clusters of related data in a database is first presented. This is 
followed by a discussion of the mathematical model underlying the methods described herein, 
including exemplary approaches for identifying clusters in a timely manner. Next, various 
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applications of these methods for different types of databases are presented. Finally, a useful 
mechanism for displaying the identified relationships that exist among the data is described. 

[1024] FIG. 1 illustrates a system 100 according to an embodiment of the present 
invention. System 100 includes a computer processor 110 operatively coupled to a data 
5 storage device 120 via a communication link 130. Computer processor 1 10 may be a general- 
purpose microprocessor or a bank of parallel processors or any other computer processing 
platform as would be apparent. Communication link 130 may be an internal or extemal data 
bus, a network (wired or wireless), or any other communication link for facilitating the access 
and transfer of data between computer processor 110 and data storage device 120 or other 
10 source of data (not otherwise illustrated). Data storage device 120 may include a single 
storage medium or bank of storage media capable of storing a database 140, or other 
collection of data, as would be apparent. 

[1025] Database 140 may be a collection of data organized and accessed in a variety of 
m ways according to well-known techniques. Generally, database 140 mcludes N number of 
15 data records 150 (illustrated in FIG. 1 as a data record 150A, a data record 150B, etc., and a 
111 data record 1 50N). Each data record 1 50 includes M number of data fields 1 60 (illustrated in 
1^ FIG. 1 as a data field 160 A, a data field 160B, and a data field 160M). As would be apparent, 
^ database 140 may be a subset of a larger database (not illustrated) that has greater than N 
<| number of data records 1 50 and^r greater than M number of data fields 1 60. As would also 
y20 be apparent, database 140 may be a real-time stream of data collected fi:om various sensors, 

measurement devices, or the like, during an information gathering session, such as, for 

example, an experiment. 

[1026] The present invention is now described with reference to an exemplary data space 
200 as illustrated in FIG. 2. Each of data records 150 may be considered a data point 220 
25 (illustrated collectively as data points 220A-P) in an M-dimensional data space 200. As 

illustrated in FIG. 2, data space 200 is a two-dimensional space (selected for purposes of ease 
of illustration and understanding, and not by way of limitation) having an x-axis and a y-axis. 
In data space 200, each data point 220 corresponds to a data record 150 having at least a first 
data field 160A and a second data field 160B, respectively. 
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[1027] In one embodiment of the present invention, data space 200 is a normalized data 
space. In this embodiment, the data included in data records 150 is normalized across data 
fields 160 so that the data within these data fields has a predetermined mean and a 
predetermined variance. For example, the data may be normalized to have a mean of zero and 
5 a variance of one. Other predetermined means and variances may be used as would be 

apparent. This normalization is useful particularly where units of measurement differ across 
data fields 160. 

[1028] As illustrated in FIG. 2, various data points 220 have a closer relationship to some 
data points 220 than to other data points 220. More specifically, data point 220A is more 
10 closely related to data points 220B and 220C than it is to the other data points 220 with regard 
to data fields 160A and 160B. Likewise, data point 220J is more closely related to data points 
220G, 220H, and 2201 than it is to the other data points 220, again with regard to data fields 
^ 160A and 160B. Note that for other data spaces 200 having other data fields 160 (/.e., having 
Qj different x-axes and/or y-axes and/or additional axes), relationships among these data points 
5 220 may change as would be apparent. 

' [1029] While the relationships among data points 220 illustrated in FIG. 2 are easily 
|;,^ identified by a casual human observer, other relationships are less easily identified, 
Jr particularly as the number of data points (N) increases or as the number of data fields (M) 
il increases. Furthermore, computers are unable (at least at present) to make even the simplest 
y20 of "casual observations." The present invention provides a mechanism for dynamically 
identifying clusters of related data in data space 200, 

[1030] According to the present invention, a probe 240 is inserted or "launched" into data 
space 200 at an initial location. In an embodiment of the present invention, probe 240 is a 
mathematical construct that operates to identify clusters of related data in data space 200. 
25 Probe 240 is attracted to data points 220 based on a relative proximity of probe 240 to each of 
data points 220. Proximate data points 220 attract probe 240 more than distant data points 
220. Probe 240 "moves" through data space 200 based on the attraction of data points 220 
until probe 240 setfles at an equilibrium point. Various equilibrium points may be reached 
within data space 200 depending upon the initial location selected for probe 240. 
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[1031] In one embodiment, the initial location for probe 240 is randomly selected from 
among all possible locations in data space 200. In other embodiments, the initial location is 
selected in various ways tailored, for example, to reduce computation time, etc., as will be 
discussed in further detail below. 

5 [1032] FIG. 3 illustrates an operation of an embodiment of the present invention. In an 
operation 310, probe 240 is launched into data space 200 from an initial position. In an 
operation 320, a cluster is dynamically identified by allowing data points 220 to attract probe 
240 from the initial position to an equilibrium point. In an operation 330, once the 
equilibrium point is reached by probe 240, a number of clusters identified in data space 200 is 
10 incremented. In an optional operation 340, a location of the identified cluster is stored. In 
one embodiment, the equilibrium point is stored as a representation of the location of the 
identified cluster. 

[1033] According to the present invention, after the cluster is identified, probe 240 is 
gi subsequently launched from a new initial position and operations 320-330 are repeated to 
|3 15 identify other clusters in data space 200. The operations of launching probe 240 firom new 

initial positions and identifying clusters in data space 200 are repeated until no imique clusters 
^^1: are identified. In this manner, the present invention identifies all the clusters in data space 
pi, 200 without having any a priori knowledge or estimate of the number of the clusters therein, 

0 [1034] FIG. 4 illustrates an embodiment of operation 320 in further detail. In an 
20 operation 41 0, a new position for probe 240 is determined based on a current position of 
probe 240 and its relationship to data points 220 in data space 200. This determination may 
utilize various attractor or similarity functions. According to the present invention, various 
similarity functions may be used including force functions, coulomb force functions, power 
functions of radial distance, etc. In addition, dissimilarity functions (/.e., the inverse of a 
25 similarity function one of which may be, for example, distance) may be used as would be 
apparent. Furthermore, dissimilarity functions may be tailored to a particular application 
based on characteristics of the data. 

[1035] One class of similarity functions found to be useful in the present invention are 
Lyapunov functions, a class of functions whose properties include having a locally negative 
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definite first derivative. For this class of similarity functions, the equilibrium point identified 
according to the present invention is actually a local minimum of the similarity function 
within data space 200. 

[1036] In one embodiment of the present invention, a potential function is used. More 
5 specifically, this potential function is approximated by a product of a weight function and a 
quadratic function, namely: 

vy = R/exp(-R//( ')) 

where 

vj is the potential between the probe and the data point, 
1 0 Ry is the dissimilarity/distance between the probe and the data point, and 

^ is an estimate of the noise variance associated with R. 

% A plot of this potential function versus dissimilarity/distance is illustrated in FIG. 7, where a 
C value of 5 is assumed for the noise variance associated with dissimilarity/distance, R. In one 
m embodiment of the present invention, R, represents the Euclidean distance between the probe 
3 5 and the respective data point. This function requires an estimate of the noise variance of the 
0^ particular measuring device used to collect the data associated with the corresponding data 
field 160. As would be apparent, the noise variance provides a measure of the uncertainty 
^ associated with the measurement. 

O [1037] According to the present invention, probe 240 is moved within data space 200 (/.e., 
20 the position of probe 240 is adjusted) in order to minimize the sum of the potential function 
for each of the N data points 220 in data space 200, namely to minimize: 

N 
7=1 

In this embodiment of the present invention, probe 240 is moved within data space 200 in an 
effort to minimize the sum of the potential function, V, according to the following: 

1 ^ 
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where 
and where: 

is the k^^ component of the new position of the probe at iteration t+1 

is the component of the current position of the probe at iteration t 

Xkj is the li^ component of the data point 

is the weighting value for the data point at iteration t 

15 At is the sum of the weighting values over all data points at iteration / 

Z/ is the normalized Euclidean distance between the probe and the data point 

N is the number of data points and 

|;: M is the number of data fields, or components, in each data point. 

r^^^ [1038] The function of similarity set forth above defines a force in a dynamic system such 

that a Lyapunov function exists. 

Q [1039] Once the new probe position is determined, in a decision operation 420, the new 
^''"^ 25 probe position is compared with the current probe position to determine whether the probe has 
converged to an equilibrium point, or in this case, a local minimum, within data space 200. If 
the new probe position and the current probe position are approximately the same position 
{Le., the new probe position and the current probe position are within some predetermined 
distance of one another as would be apparent), a local minimum of the sum of potential 
30 functions has been reached. In an operation 440, a cluster is identified at that position, or 

alternately in some embodiments, at a position corresponding to the data point 220 nearest to 
that position for purposes of convenience. If the new probe position is not approximately the 
same position as the current probe position, in an operation 430, probe 240 is moved from the 
current probe position to the new probe position and processing continues at operation 410. 
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As illustrated, operations 410, 420, and 440 are iteratively performed until the local minimum 
is reached and a cluster can be identified as in operation 430. 

[1040] FIG. 5 illustrates a trajectory 500 of probe 240 as it moves through data space in 
accordance with the present invention. At an iteration t=0, probe 240 is launched from an 
5 initial position 5 1 0 as described above with respect to operation 310. After performing 

operations 410, 420, and 440 in an iteration t^l, probe 240 is moved from initial position 510 
to a new position 520. Operations 410, 420, and 440 are again performed during an iteration 
t^2 resulting in probe 240 moving from position 520 to a new position 530. These iterations 
continue, moving probe 240 along trajectory 500 until, for example, a position 550 is reached. 
10 In accordance with the present invention, subsequent iterations do not substantially alter the 
position of probe 240. At this point in trajectory 500, a cluster is deemed identified. In one 
embodiment of the present invention, the position of the cluster may be identified as position 
550, whereas in other embodiments of the present invention, the position of the cluster may be 

m identified as the position of the nearest data point 220 (which as illustrated in FIG. 5 

f Jl 5 corresponds to data point 220C). 

tf'^ [1041] FIG. 6 illustrates data space 200 after having four clusters 210 (illustrated as 
clusters 210A-D) of related data identified therein. Also illustrated in FIG. 6 are final 
positions 610 (illustrated as final positions 610A-D) for each of clusters 210 according to one 

IJ embodiment of the present invention. 

20 [1042] Various embodiments of the present invention may employ different mechanisms 
for selecting an initial position from which to launch probe 240. Some of these mechanisms 
are described in fiirther detail. In one embodiment of the present invention, probe 240 is 
launched from each possible position in data space 240. Such an exhaustive approach, while 
theoretically possible within a finite data space 240, may be computationally inefficient. 

25 [1043] In another embodiment of the present invention, initial positions within a 

particular distance, range, or other non-Euclidean measure of "proximity," {e.g., 1 /(similarity 
+ 1 )) of identified cluster 2 1 0, or similarly, within a particular proximity of final position 510, 
are not considered as initial positions from which to launch probe 240. Probes 240 launched 
within this particular proximity of either identified cluster 2 1 0 or final position 5 1 0 are likely 
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to settle at that same identified cluster 210 or final position 510 rather than at a unique cluster. 
This proximity may be predetermined, fixed, or dynamically adjusted based on various 
characteristics of data points 220 in data space 200 as would be apparent. 

[1044] In another embodiment of the present invention, initial positions within a 
5 particular proximity of trajectory 500 are not considered as initial positions from which to 
launch probe 240. Probes 240 launched within this particular proximity of trajectory 500 are 
likely to settie at the same cluster 210 or final position 510 associated with trajectory 500 and 
thus fail to identify a unique cluster within data space 200. 

[1045] In another embodiment of the present invention, probes 240 are launched from 
10 data points 220. This embodiment of the present invention limits a number of possible initial 

positions for probe 240 to N, the number of data points 220 in data space 200. As a further 
S embodiment of the present invention, the potential initial positions for probe 240 may be 
5 further reduced by assigning various data points 220 to the identified clusters 210 and not 
Lil considering these assigned data points 220 as initial positions from which to launch probe 
2 15 240. Data points 220 may be assigned to various ckisters based on, for example, being within 

a certain proximity to cluster 210. Data points 220 may be assigned to clusters in other 

manners as would be apparent. 

y [1046] FIG. 6 is now used to further illustrate how initial positions may be selected in 
O accordance with this embodiment of the present invention. Initially, probe 240 may be 
20 launched from data point 220A. From this probe, cluster 21 OA is identified. According to 

this embodiment of the present invention, data points 220A, 220B, and 220C may be assigned 
identified cluster 21 OA as being within a certain proximity of cluster 21 OA. These data points 
220A-C would not subsequentiy be selected as initial positions for probe 240 because in all 
likelihood, the same cluster, namely cluster 21 OA, would be identified. As additional clusters 
25 210 are identified, additional data points 220 are removed from consideration as potential 
initial positions for probe 240. In the example illustrated in FIG. 6, fifteen potential initial 
positions are available from which to launch probe 240 before any clusters 210 are identified. 
After cluster 21 OA is identified (and data points 220A-C assigned thereto), only twelve 
potential initial positions remain. The identification of cluster 21 OB would remove four 
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additional potential initial positions from consideration. The identification of cluster 2 IOC 
would remove three initial positions and the identification of cluster 21 OD would remove four 
initial positions from consideration. In this example and according to this embodiment of the 
present invention, launching four probes in data space 200 would be sufficient to identify all 
5 clusters 2 1 0 of related data therein. 

[1047] In an alternate embodiment of the present invention, data points 220 may be 
assigned to clusters 210 using fuzzy logic, /.e., a particular data point 220 may belong to a 
first cluster 210 to a certain degree (or probability) and to a second cluster to a certain degree 
(or probability). For example, as illustrated in FIG. 6, data point 220K may belong by 
10 varying degrees to each of clusters 2 IOC and 210D as would be apparent. 

[1048] Once a number of clusters 210 within a particular data space 200 (and hence 
within database 140) is dynamically determined by the present invention, various other 
■0 conventional clustering techniques may be subsequently used to assign data points 220 to 
ijl clusters 210. For example, the present invention may be used to djmamically determine the 
^il 5 number of clusters 210 within database 140. This number may then be used as an inpvit 
parameter to perform, for example, a conventional k-means clustering analysis. 

^ [1049] The present invention as thus described has many applications for identifying 
% potential relationships among data. One potential application of the present invention is as a 
£S tool for identifying relationships among gene expression profiles for a series of biological 
20 experiments. In this application, N gene expression profiles may be generated for each of a 
series of M biological experiments. Such profiles are routinely generated and stored in 
databases (e.g., various experiments designed and performed with Drosophila microarrays). 
The present invention may be used to identify those clusters of genes that react in similar 
manners to the biological experiments. If a known gene is a member of the cluster, one can 
25 infer similar properties about the other genes in that cluster. By comparing the properties of 
clusters of a particular gene clone among different sets of experiments, one can infer that the 
gene is functionally variant, e.g., a splice variant gene. 

[1050] Another potential application of the present invention is as a tool for identifying 
similar or related records in a database (e.g., mailing lists, etc.) Various companies compile 
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demographic information associated with consumers and sell this information as lists to mail- 
order retailers for targeted advertising, catalogs, etc. Often times, information for the same 
individual may be obtained from multiple sources and therefor reside as multiple records 
within the retailer's database. Altemately, records may reside in the database that identify 
5 husband and wife in the same household. The mail-order retailer may wish to identify this 
related information so as to reduce the number of catalogs it sends to these consumers, i.e., 
only send one copy of a catalog to an individual or household. 

[1051] A mechanism for displaying the identified relationships that may exist among the 
data in a database is now described. According to the present invention, a linear display of 
10 one of data fields 160 versus its respective data point 150 is plotted. In one embodiment of 
the present invention, this so-called "principal data field" {e.g., a component of interest, a user 
selected component, a component displaying greatest dynamic range either raw or 

If normalized, a component displaying previously unknown or unquantified results, etc.) is 

{Q sorted, its mean determined, and displayed in terms of its degree of deviation from the mean. 

f 5 15 In other embodiments of the present invention, a "score" or other scalar is compvited using 

:|: several data fields as would be apparent. 

U [1052] In some embodiments of the present invention, the degree of deviation may be 

displayed as a first color for positive deviations and as a second color for negative deviations. 
CJ The relative intensity or brightness of the color displayed may also correspond to the degree 
n 20 of the deviation, i.e., a bright color may correspond to a data value with a greater deviation 
from the mean than that of a dark color. 

[1053] In an alternate embodiment of the present invention, cross-hatching rather than 
color may be used with "left-hand" cross-hatching corresponding to negative deviations and 
"right-hand" cross-hatching corresponding to positive deviations. The relative density of the 
25 cross-hatching may correspond to the degree of the respective deviations. FIG. 9 illustrates 
this embodiment in fiirther detail. 

[1054] Two colors with varying intensity and two forms of cross-hatching with varying 
density represent two indicia that may be used to convey a relative degree (value) and 
direction (sign) of a parameter to a user. Other indicia may be used as would be apparent. 



-13- 



Attorney Docket No.: NOBI-OOl/OOUS 

Furthermore, to the extent that either degree or direction is imnecessary, only a portion of the 
indicia would be necessary as would also be apparent. For example, if only the direction or 
sign of the deviation was relevant, both colors might be used without varying their intensity. 
Likewise if only the degree of deviation was relevant, only one color of varying intensity 
5 might be used. 

[1055] The linear display of the present invention may be extended across multiple 
"principal data fields." For example, FIG. 8. illustrates a linear display 800 of a principal data 
field 830 as it varies across data points 810 as well as another independent parameter 820. 
Linear display 800 provides a visual indication of how data fields 830 deviate fi-om a mean 
10 associated each data field 830 as well as across independent parameter 820. 

[1056] In this example, each data point 810 corresponds to a particular gene 810 
% (illustrated in FIG, 8 as "GENE 1" 810A, "GENE 2" 810B, etc., and "GENE N" 810 N) being 
O analyzed while independent parameter 820 corresponds to a particular experiment 820 
35 (illustrated in FIG. 8 as "EXPERIMENT 1" 820A, "EXPERIMENT 2" 820 B, etc., and 
2l 5 "EXPERIMENT M" 820 M) conducted across all genes 810, In this example, principal data 
^'^ field 830 corresponds to an expression of the particular gene 8 1 0 during the particular 
^ experiment 820. 

|: [1057] In one embodiment of the present invention, linear display 800 is rendered by first 
3: computing a mean of the expression of each gene 8 1 0 for each experiment 820, selecting one 
20 of experiments 820, and sorting genes 810 based on a degree of deviation in expression for 
the selected experiment. In an alternate embodiment of the present invention, rather than 
selecting one of the experiments of which to base the sort, a measure, or "score" of the 
collective degree of deviation in expression is determined for each gene 810 across the M 
experiments 820 (or some subset thereof) and this measure may provide the basis for sorting 
25 genes 810. Various measures are available, for example, a sum of the deviations for each of 
the experiments, or other such linear transformations of the data, as would be apparent. Such 
a linear display 800 might be usefijl for determining which genes 810 increase (or decrease) in 
expression based on a set of conditions associated with experiments 820. 
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[1058] In one embodiment of the present invention^ genes 810 that demonstrate a greater 
degree of increased expression across all experiments 820 would tend toward the top of linear 
display 800 whereas genes 810 that demonstrate a greater degree of decreased expression 
across all experiments 820 would tend toward near the bottom. Furthermore, genes 810 that 
demonstrate little change in expression or some degree of increase in expression for some 
experiments 820 and some degree of decrease in expression for other experiments 820 would 
tend toward the middle of middle of Knear display 800. 

Conclusion 

[1059] While various embodiments of the present invention have been described above, it 
should be understood that they have been presented by way of example only, and not 
limitation. Thus, the breadth and scope of the present invention should not be Umited by any 
of the above-described exemplary embodiments, but should be defined only in accordance 
with the following claims and their equivalents. 

[1060] The previous description of the preferred embodiments is provided to enable any 
person skilled in the art to make or use the present invention. While the invention has been 
particularly shown and described with reference to preferred embodiments thereof, it will be 
understood by those skilled in the art that various changes in form and details may be made 
therein without departing from the spirit and scope of the invention. 
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